跳到主要内容

Go 跟踪 http 之 WithClientTrace 包

httptrace 包提供跟踪 HTTP 客户端请求中的事件的机制。

package main

import (
"fmt"
"log"
"net/http"
"net/http/httptrace"
)

func main() {
req, _ := http.NewRequest("GET", "http://example.com", nil)
trace := &httptrace.ClientTrace{
// 包含有关获取的连接的信息
GotConn: func(connInfo httptrace.GotConnInfo) {
fmt.Printf("Got Conn: %+v\n", connInfo)
},
DNSDone: func(dnsInfo httptrace.DNSDoneInfo) {
fmt.Printf("DNS Info: %+v\n", dnsInfo)
},
}
req = req.WithContext(httptrace.WithClientTrace(req.Context(), trace))
_, err := http.DefaultTransport.RoundTrip(req)
if err != nil {
log.Fatal(err)
}
}